package com.leetcode_Onequestion;

/**
 * @Author jsh
 * @Date 2023/3/15 22:51
 * @Version 1.0
 *
 * n 座城市和一些连接这些城市的道路 roads 共同组成一个基础设施网络。每个 roads[i] = [ai, bi] 都表示在城市 ai 和 bi 之间有一条双向道路。
 *
 * 两座不同城市构成的 城市对 的 网络秩 定义为：与这两座城市 直接 相连的道路总数。如果存在一条道路直接连接这两座城市，则这条道路只计算 一次 。
 *
 * 整个基础设施网络的 最大网络秩 是所有不同城市对中的 最大网络秩 。
 *
 * 给你整数 n 和数组 roads，返回整个基础设施网络的 最大网络秩 。
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode.cn/problems/maximal-network-rank
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */

public class leetcode_1615 {

    public static void main(String[] args) {

    }
    public int maximalNetworkRank(int n, int[][] roads) {
        boolean[][] connect = new boolean[n][n];

        int[] degree = new int[n];
        for (int[] v : roads){
            connect[v[0]][v[1]] = true;
            connect[v[1]][v[0]] = true;
            degree[v[0]] ++;
            degree[v[1]] ++;
        }

        int max = 0;
        for (int i = 0; i < n; i++) {
            for (int j = i+1; j < n; j++) {
                max = Math.max(max, degree[i] + degree[j] - (connect[i][j] ? 1 : 0));
            }
        }
        return max;
        
    }
}
